<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>文章列表</title>
    <link rel="stylesheet" href="./libs/bootstrap/css/bootstrap.min.css">
    <link rel="stylesheet" href="./css/reset.css">
    <link rel="stylesheet" href="./css/iconfont.css">
    <link rel="stylesheet" href="./css/main.css">
    <script src="./libs/jquery-1.12.4.js"></script>
    <!-- 引入模板引擎js文件 -->
    <script src="./libs/template-web.js"></script>
    <!-- 引入分页的js相关文件 -->
    <script src="./libs/bootstrap/js/bootstrap.min.js"></script>
    <script src="./libs/jquery.twbsPagination.js"></script>
</head>

<body>
    <div class="container-fluid">
        <div class="common_title">
            文章列表
        </div>
        <div class="container-fluid common_con">
            <div class="row opt_btns">
                <div class="col-xs-6">
                    <form class="form-inline">
                        <select id="selCategory" name="" class="form-control input-sm">
                            <option value="">所有分类</option>
                            <option>未分类</option>
                            <option>奇趣事</option>
                            <option>会生活</option>
                            <option>爱旅行</option>
                        </select>
                        <select id="selStatus" name="" class="form-control input-sm">
                            <option value="">所有状态</option>
                            <option value="草稿">草稿</option>
                            <option value="已发布">已发布</option>
                        </select>
                        <button id="btnSearch" class="btn btn-default btn-sm">筛选</button>
                    </form>
                </div>
                <div class="col-xs-6">
                    <a href="article_release.html" class="btn btn-success btn-sm pull-right" id="release_btn">发表文章</a>
                </div>
            </div>
            <table class="table table-striped table-bordered table-hover mp20">
                <thead>
                    <tr>
                        <th>标题</th>
                        <th>作者</th>
                        <th>分类</th>
                        <th class="text-center">发表时间</th>
                        <th class="text-center">状态</th>
                        <th class="text-center" width="100">操作</th>
                    </tr>
                </thead>
                <tbody>
                    <tr>
                        <td>王积千造统最头</td>
                        <td>杰克</td>
                        <td>奇趣事</td>
                        <td class="text-center">2017-06-08 07:08:46</td>
                        <td class="text-center">已发布</td>
                        <td class="text-center">
                            <a href="article_edit.html" class="btn btn-default btn-xs">编辑</a>
                            <a href="javascript:void(0);" class="btn btn-danger btn-xs delete">删除</a>
                        </td>
                    </tr>
                </tbody>
            </table>
            <div class="row text-center">
                <ul class="pagination" id="pagination"></ul>
                <p id="nodata">没有数据！</p>
            </div>
        </div>
    </div>
    <script src="./libs/http.js"></script>
    <!-- 创建一个文章列表模板 -->
    <script id="articletemp" type="text/html">
        <option value="">所有分类</option>
        {{each data v}}
        <option value="{{v.id}}">{{v.name}}</option>
        {{/each}}
    </script>
    <script id="tbodytemp" type="text/html">
        {{each data.data v}}
        <tr>
            <td>{{v.title}}</td>
            <td>{{v.author}}</td>
            <td>{{v.category}}</td>
            <td class="text-center">{{v.date}}</td>
            <td class="text-center">{{v.state}}</td>
            <td class="text-center">
                <a href="article_edit.html?id={{v.id}}" data-id="" class="btn btn-default btn-xs">编辑</a>
                <a href="javascript:void(0);" data-id="{{v.id}}" class="btn btn-danger btn-xs delete">删除</a>
            </td>
        </tr>
        {{/each}}
    </script>
    <script>
        $(function () {
            //发送Ajax请求，获取到所有文章类别
            $.ajax({
                type: 'get',
                url: BigNew.category_list,
                success: function (backData) {
                    if (backData.code == 200) {
                        let res = template('articletemp', backData)
                        $('#selCategory').html(res)
                    }
                }
            })
            //
            let mypage = 1
            function ajData(page, callback) {
                $.ajax({
                    type: 'get',
                    url: BigNew.article_query,
                    data: {
                        type: $('#selCategory').val(),
                        state: $('#selStatus').val(),
                        page: page,
                        perpage: 3
                    },
                    success: function (backData) {
                        let res = template('tbodytemp', backData)
                        $('tbody').html(res)
                        if (backData.data.data.length != 0 && callback != null) {
                            callback(backData)
                            $('#pagination').show().next('#nodata').hide()
                        } else if (backData.data.data.length == 0 && mypage == 1) {
                            $('#pagination').hide().next('#nodata').show()
                        } else if (backData.data.totalPage == mypage - 1 && backData.data.data.length == 0) {
                            mypage -= 1
                            //页码重绘
                            $('#pagination').twbsPagination('changeTotalPages', backData.data.totalPage, mypage)
                        }
                    }
                })
            }


            //第一次调用函数，一进页面就执行的代码
            ajData(mypage, function (backData) {
                //分页
                $('#pagination').twbsPagination({
                    first: '首页',
                    prev: '上一页',
                    next: '下一页',
                    last: '尾页',
                    totalPages: backData.data.totalPage,
                    visiblePages: 8,
                    onPageClick: function (event, page) {
                        mypage = page
                        //第二次调用
                        ajData(mypage, null)

                    }
                })
            })

            //第三次调用
            //点击筛选按钮，筛选出对应的文章类别并展示
            $('#btnSearch').on('click', function (e) {
                mypage = 1
                //阻止按钮默认的提交行为
                e.preventDefault();
                //再次发送Ajax请求，将筛选出来的数据展示到页面
                ajData(1, function (backData) {
                    //页码重绘
                    $('#pagination').twbsPagination('changeTotalPages', backData.data.totalPage, 1)
                })

            })


            //点击删除按钮删除文章
            //通过事件委托注册事件
            $('tbody').on('click', 'a.delete', function (e) {
                //阻止a链接的跳转
                e.preventDefault()
                //发送Ajax请求删除文章
                if (confirm('您确定要删除吗？')) {
                    $.ajax({
                        type: 'post',
                        url: BigNew.article_delete,
                        data: {
                            id: $(this).attr('data-id'),
                        },
                        success: function (backData) {
                            if (backData.code == 204) {
                                alert('删除成功！')
                                //第四次调用
                                ajData(mypage, function (backData) {
                                    //页码重绘
                                    $('#pagination').twbsPagination('changeTotalPages', backData.data.totalPage, mypage)
                                })

                            }
                        }
                    })
                }

            })


            //点击发表文章按钮跳转到文章发表页
            $('#release_btn').on('click', function () {
                parent.$('ul.level02>li:eq(1)').trigger('click')
            })
            // //发送Ajax请求，将所有文章展示在页面上
            // $.ajax({
            //     type: 'get',
            //     url: BigNew.article_query,
            //     data: {
            //         type: $('#selCategory').val(),
            //         state: $('#selStatus').val(),
            //         page: 1,
            //         perpage: 6
            //     },
            //     success: function (backData) {
            //         console.log(backData)
            //         let res = template('tbodytemp', backData)
            //         $('tbody').html(res)
            //         //分页
            //         $('#pagination').twbsPagination({
            //             first: '首页',
            //             prev: '上一页',
            //             next: '下一页',
            //             last: '尾页',
            //             totalPages: backData.data.totalPage,
            //             visiblePages: 8,
            //             onPageClick: function (event, page) {

            //                 $.ajax({
            //                     type: 'get',
            //                     url: BigNew.article_query,
            //                     data: {
            //                         type: $('#selCategory').val(),
            //                         state: $('#selStatus').val(),
            //                         page: page,
            //                         perpage: 6
            //                     },
            //                     success: function (backData) {
            //                         console.log(backData)
            //                         let res = template('tbodytemp', backData)
            //                         $('tbody').html(res)

            //                     }
            //                 })
            //             }
            //         })

            //     }
            // })


            //

            // //点击筛选按钮，筛选出对应的文章类别并展示
            // $('#btnSearch').on('click', function (e) {
            //     //阻止按钮默认的提交行为
            //     e.preventDefault();
            //     //再次发送Ajax请求，将筛选出来的数据展示到页面
            //     $.ajax({
            //         type: 'get',
            //         url: BigNew.article_query,
            //         data: {
            //             type: $('#selCategory').val(),
            //             state: $('#selStatus').val(),
            //             page: 1,
            //             perpage: 6
            //         },
            //         success: function (backData) {
            //             if (backData.code == 200) {
            //                 let res = template('tbodytemp', backData)
            //                 $('tbody').html(res)

            //                 //页码重绘
            //                 $('#pagination').twbsPagination('changeTotalPages', backData.data.totalPage, 1)
            //             }

            //         }
            //     })

            // })
            //
            // //点击删除按钮删除文章
            // //通过事件委托注册事件
            // $('tbody').on('click', 'a.delete', function (e) {
            //     //阻止a链接的跳转
            //     e.preventDefault()
            //     //发送Ajax请求删除文章
            //     if (confirm('您确定要删除吗？')) {
            //         $.ajax({
            //             type: 'post',
            //             url: BigNew.article_delete,
            //             data: {
            //                 id: $(this).attr('data-id'),
            //             },
            //             success: function (backData) {
            //                 if (backData.code == 204) {
            //                     alert('删除成功！')
            //                     //发送Ajax请求，将最新数据展示到页面上
            //                     $.ajax({
            //                         type: 'get',
            //                         url: BigNew.article_query,
            //                         data: {
            //                             type: $('#selStatus').val(),
            //                             state: $('#selStatus').val(),
            //                             perpage: 6
            //                         },
            //                         success: function (backData) {
            //                             console.log('文章筛选', backData)
            //                             let res = template('tbodytemp', backData)
            //                             $('tbody').html(res)
            //                         }
            //                     })
            //                 }
            //             }
            //         })
            //     }

            // })

        })
    </script>
</body>

</html>